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4 A method for representing multi-terminal CFLOBDDs in the memory of a computer so that equality of 
multi-terminal CFLOBDDs can be tested in constant time, comprising the following steps: 

a. Allocate a table in which to store unique representitives of values of type CFLOBDD. 

b. Use the tabic to perform mcmoization during operations that construct values of type CFLOBDD in 
the computer memory, so that only a single representative is ever constructed for each value of type 
CFLOBDD. 

c. Determine whether two values of type CFLOBDD are equal by testing whether then addresses in the 
computer memory are equal. 

5 A method for obtaining, in the memory of a computer, a level-/: CFLOBDD that, represents a constant- 
valued function of the form Xx 0 ,x u x-^^.v, comprising the following steps: 

a. Apply routine ConstantCFLOBDD(k,v) to form a CFLOBDD lepreseutation m inemoiv. 
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6 A method for obtaining, in the memory of a computer, a level-A; CFLOBDD that represents a Boolean- 
valued projection function of the form Axo, x\, . . . , x 2 *_i -^i, where i ranges from 0 to 2* - 1, comprising the 
following steps: 

a. Apply routine ProjectionCFLOBDD(k.i) to form a CFLOBDD representation in memory. 

7 A method for obtaining, in the memory of a computer, a level-A: CFLOBDD that represents a step 
function of the form 



where i ranges from 0 to 2 2 * , comprising the following steps: 

a. Apply routine StepCFL0BDD(k,i,vl,v2) to form a CFLOBDD representation in memory. 

8 A method for obtaining a representation of a Boolean- valued CFLOBDD in the memory of a comput.ei, 
comprising the following steps: 

a. Apply routine ComplementCFLOBDD(c) on a given Boolean-valued CFLOBDD c to form a Boolean- 
valued CFLOBDD representation in memory. 

9 A method for obtaining a representation of a multi-terminal CFLOBDD in the memory of a computer, 
comprising the following steps: 

a. Apply routine FlipValueTupleCFLOBDD(c) on a given multi-terminal CFLOBDD c to form a multi- 
terminal CFLOBDD representation in memory. 

10 A method for obtaining a representation of a multi-terminal CFLOBDD in the memory of a computer, 
comprising the following steps: 

a. Apply routine ScalarMultiplyCFLOBDD(c.v) on a given multi-terminal CFLOBDD c and value v to 
form a multi-terminal CFLOBDD representation in memory. 

11 A method for obtaining a representation of a Boolean- valued CFLOBDD in the memory of a computer, 
comprising the following steps: 

a. Apply routine BinaryApplyAndReduce for evaluating binary Boolean operations on Boolean-valued 
CFLOBDDs to form a Boolean-valued CFLOBDD representation in memory. 

12 A method for obtaining a representation of a multi-terminal CFLOBDD in the memory of a computer, 
comprising the following steps: 

a. Apply routine BinaryApplyAndReduce for evaluating binary operations on multi-terminal CFLOBDDs 
to form a multi-terminal CFLOBDD representation in memory. 

13 A method for obtaining a representation of a Boolean-valued CFLOBDD in the memory of a computer, 
comprising the following steps: 



a. Apply routine TernaryApplyAndReduce for evaluating ternary Boolean operations on Boolean-valued 
CFLOBDDs to form a Boolean-valued CFLOBDD representation in memory 




if the number whose bits are x 0 Xi . ..x.,i._ l is .strictly 1< •>,.-, i h.m , 

if the number whose bits are x 0 xi ...x 2 i.-i is greater than or equal to i 
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14 A method for obtaining a representation of a Boolean-valued CFLOBDD in the memory of a computer, 
comprising the following steps: 

a. Apply routine TernaryApplyAndReduce with the operation ITE as the fourth argument, and evaluate 
binary Boolean operations on Boolean-valued CFLOBDDs according to the table given hi Figure 28 
to form a Boolean-valued CFLOBDD representation in memory. 

15 A method for obtaining a representation of a multi-terminal CFLOBDD in the memory of a computer, 
comprising the following steps: 

a. Apply routine TernaryApplyAndReduce for evaluating ternary operations on multi-terminal CFL- 
OBDDs to form a multi-terminal CFLOBDD representation in memory. 

16 A method carried out by a computer for constructing a multi-terminal CFLOBDD that i. pM-iM't- ilu 
Kronecker product of two matrices A and B, where the values of A are drawn horn {w,\. »•„, \ ami re- 
values of B are drawn from {vo, . - . , v n }, comprising the following steps: 

a. Create representations of the matrices A and B as level-fc multi-terminal CFLOBDDs in the computer 
memory, under the interleaved variable ordering. (Without loss of generalit}', we can make the as- 
sumption that, the sequences of exit vertices in the two multi-terminal CFLOBDDs are mapped i.o i.he 
values [w 0 , . . .,w m ] and [i> 0 , . . . , v„], respectively.) 

b. Create a level k + 1 grouping that has m + 1 middle vertices, corresponding to the values [w 0 , to m J, 
and (m + l)(n + 1) exit vertices, corresponding to the values 

[w tVj : t £ [0..m),j € [0..n]]. 

c. For each middle vertex, which corresponds to some value w t , for 0 < i < m, create a ^-connection to 
the proto-CFLOBDD of B, and a return tuple from the exit vertices of the proto-CFLOBDD of B to 
the exit vertices of the level k + 1 grouping that, correspond to the values [w t v a , . . ., w,v„]. 

d. If any of the values in the sequence 

: i € [0..m],j € [0..n]] 

are duplicates, make an appropriate call on Reduce to fold togethei the classes of <>\-jt v<>!tin- >h.v 
are associated with the same value, thereby creating a multi-terminal CFLOBDD m the compurei 
memory. 

17 A method carried out by a computer for constructing a multi-terminal CFLOBDD that represents the 
Reed-Muller transform matrix R 2 , , for j > 0, comprising the following steps: 

a. Apply routine ReedMullerCFLOBDD ( j + 1 ) to form a multi-terminal CFLOBDD representation in mem- 
ory. 

18 A method carried out by a computer for constructing a multi-terminal CFLOBDD that represents the 
inverse Reed-Muller transform matrix 5 2J , for j > 0, comprising the following steps: 

a. Apply routine InverseReedMullerCFLOBDD( j+1) to form a multi-terminal CFLOBDD representation 
in memory. 
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19 A method carried out by a computer for constructing a multi-terminal CFLOBDD that represents the 
Walsh transform matrix W 23 , for j > 0, comprising the following steps: 

a. Apply routine WalshCFLOBDD(j+l) to form a multi-terminal CFLOBDD representation in memory. 

20 A method carried out by a computer for constructing a multi-terminal CFLOBDD that represents the 
Boolean Haar Wavelet transform matrix H 2 i, for j > 0, comprising the following steps: 

a. Apply routine HaarCFLOBDD ( j + 1 ) to form a multi-terminal CFLOBDD representation in memory. 

21 A method carried out by a computer for compressing data for subsequent storage and/or transmission 
of the data in compressed form, comprising the following steps: 

a. If the length of the signal is s, the signal is padded to be of length 2 2 \ for the smallest value of k foi 
which s < 2 2 \ For padding, a distinguished value is used that, indicates that these elements are not 
part of the signal. 

b. Building a CFLOBDD for which the values produced by evaluating successive Boolean-vatiable-to- 
Boolean-value assignments, considered in lexicographic order, match the padded signal. 

22 A method carried out by a computer for compressing data for subsequent storage and/or transmission 
of the data in compressed form, comprising the following steps: 

a. The signal to be compressed, consisting of a sequence of values drawn from some finite value space, is 
considered to be the values that label, in left-to-right order, the leaves of a decision tree 

b. If the lcngt.li of the signal is s, the decision tree used is one whose height is 2 k , where k is the smallest 
value for which s < 2 2 ; the extra leaves arc labeled with a distinguished value that indicates that 
these elements arc not part of the signal. 

c. Apply Algorithm 1 to form a multi-terminal CFLOBDD representation in memory. 

23 A method carried out by a computer for uncompressing data that has been stored in compressed form 
as a CFLOBDD c, comprising the following steps: 

a. Form the sequence in memory obtained by evaluating c for each Boolean-variable-to-Boolean-value 
assignment in lexicographic order, up until the first time that one of the distinguished v.-ihio* b<>m.j 
used to indicate a value that is not part of the signal is obtained. 

24 A method carried out by a computer for uncompressing data that has been stored in compressed form 
as a CFLOBDD c, comprising the following steps: 

a. Apply routine UncompressCFLOBDD to c to form a sequence of values in memory 

b. The sequence of values is then processed to remove any occurrences ol the distinguished value being 
used to indicate a value that is not part of the signal. 

25 A method carried out by a computer for uncompressing data that has been stored in compressed form 
as a CFLOBDD c, comprising the following steps: 

a. Apply a version of routine UncompressCFLOBDD to c, wherein piocessing is halted, and the sequence 
of values that has been formed in memory is returned as the answer, the moment that the first, 
occurrence of one of the distinguished values being used to indicate a value that is not part of the 
signal is encountered at line [48] of routine UncompressCFLDBDD. 
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